001 /* 002 * Copyright 2004 Stephen J. McConnell. 003 * 004 * Licensed under the Apache License, Version 2.0 (the "License"); 005 * you may not use this file except in compliance with the License. 006 * You may obtain a copy of the License at 007 * 008 * http://www.apache.org/licenses/LICENSE-2.0 009 * 010 * Unless required by applicable law or agreed to in writing, software 011 * distributed under the License is distributed on an "AS IS" BASIS, 012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or 013 * implied. 014 * 015 * See the License for the specific language governing permissions and 016 * limitations under the License. 017 */ 018 019 package net.dpml.metro.data; 020 021 import net.dpml.component.Directive; 022 023 /** 024 * A <code>FeatureDirective</code> declares a context entry that is itself a feature 025 * of the component including the component uri, name, working directory, or temporary 026 * directory. 027 * 028 * @author <a href="http://www.dpml.net">Digital Product Meta Library</a> 029 * @version 1.0.0 030 */ 031 public class FeatureDirective extends AbstractDirective implements Directive 032 { 033 /** 034 * Serial version identifier. 035 */ 036 static final long serialVersionUID = 1L; 037 038 /** 039 * Constant identifier for the component name feature. 040 */ 041 public static final int NAME = 0; 042 043 /** 044 * Constant identifier for the component uri feature. 045 */ 046 public static final int URI = 1; 047 048 /** 049 * Constant identifier for the component working directory feature. 050 */ 051 public static final int WORK = 2; 052 053 /** 054 * Constant identifier for the component temporary directory feature. 055 */ 056 public static final int TEMP = 3; 057 058 /** 059 * Return the feature id givcen a supplied name. 060 * @param value the feature name 061 * @return the feature id 062 */ 063 public static int getFeatureForName( String value ) 064 { 065 if( "name".equals( value ) ) 066 { 067 return NAME; 068 } 069 else if( "uri".equals( value ) ) 070 { 071 return URI; 072 } 073 else if( "work".equals( value ) ) 074 { 075 return WORK; 076 } 077 else if( "temp".equals( value ) ) 078 { 079 return TEMP; 080 } 081 else 082 { 083 final String error = 084 "Feature not recognized [" + value + "]."; 085 throw new IllegalArgumentException( error ); 086 } 087 } 088 089 //-------------------------------------------------------------------------- 090 // state 091 //-------------------------------------------------------------------------- 092 093 private final String m_key; 094 private final int m_feature; 095 096 //-------------------------------------------------------------------------- 097 // constructors 098 //-------------------------------------------------------------------------- 099 100 /** 101 * Create a new feature directive. 102 * @param key the feature name 103 * @param feature the feasture id 104 */ 105 public FeatureDirective( String key, int feature ) 106 { 107 if( null == key ) 108 { 109 throw new NullPointerException( "key" ); 110 } 111 m_key = key; 112 m_feature = feature; 113 } 114 115 //-------------------------------------------------------------------------- 116 // FeatureDirective 117 //-------------------------------------------------------------------------- 118 119 /** 120 * Return the feature key. 121 * @return the feature key 122 */ 123 public String getKey() 124 { 125 return m_key; 126 } 127 128 /** 129 * Return the feature id. 130 * @return the feature id 131 */ 132 public int getFeature() 133 { 134 return m_feature; 135 } 136 137 /** 138 * Test if the supplied object is equal to this object. 139 * @param other the object to compare with this instance 140 * @return TRUE if the supplied object is equal to this object 141 */ 142 public boolean equals( Object other ) 143 { 144 if( null == other ) 145 { 146 return false; 147 } 148 else 149 { 150 FeatureDirective feature = (FeatureDirective) other; 151 if( !m_key.equals( feature.getKey() ) ) 152 { 153 return false; 154 } 155 else 156 { 157 return m_feature == feature.getFeature(); 158 } 159 } 160 } 161 162 /** 163 * Return the hashcode for the instance. 164 * @return the instance hashcode 165 */ 166 public int hashCode() 167 { 168 int hash = m_key.hashCode(); 169 hash ^= m_feature; 170 return hash; 171 } 172 }